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(54) Control of a telephone switching system over a digital information network 



(57) Disclosed is a mechanism to integrate a tele- 
phone switching system (23) into a wide area (WAN) or 
local area (LAN) computer network, where in particular, 
a telephone switching center is controlled by a server 
computer (22) utilizing a Hypertext Transfer Protocol 
(HTTP), which is connected to a WorldWideWeb 
(WWW) network. 

Known computer telephone integration (CTl) solu- 
tions are integrated on a network server and thus have 
the drawback that due to the various different operating 
system platforms, in particular in the area of Personal 
Computers or Workstations, an interface has to be 



adapted to each client's platform. 

It is therefore proposed to provide, between a HTTP 
server (22) and the switching system (23), a control pro- 
gram (20) which enables control of a CTl application by 
the HTTP server (22), in order to integrate the function- 
ality of a switching network into the HTTP server (22). 
The proposed application (20) provides an interlace 
which uses a Universal Resource Locator (URL) speci- 
fying high level communicating functions which are 
independent of the respective interlace (21) to the 
switching system or the CTl server. 
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Description 

The present invention pertains to integration of a telephone switching system into a wide area (WAN) or local area 
(LAN) computer network, where control of a telephone system is to be performed by use of a network communication 
s protocol. In particular, the invention is concerned with control of a telephone switching center by a server computer uti- 
lizing a Hypertext Transfer Protocol (HTTP), which is connected to a WorWWideWeb (WWW) network. 

Telephone switching systems are commonly used to control communication in a telephone switching network. 
These systems hereto comprise functional units called "switching centers" which provide functions mainly for setting up 
and terminating telephone connections between end devices of participiants of the switching network. Further, among 
10 others, functions are provided for forwarding telephone calls from a called person to a third person and for setting up 
telephone conference connections between multiple subscribers. 

Thereupon these systems manage participiant admission rights and rules, control the adjustment of telephone 
end-devices, and record information about telephone connections having been switched, e.g. for telephone book-keep- 
ing or accounting purposes. 

is In order to provide the above functionality of circuit switched telephone networks in computers, recently Computer- 
Telephone Integration (CTI) applications have been developed. Hereby the functionality of witching networks is com- 
bined with functions of classical information processing. Exemplary CTI systems are a class of applications called "Call 
Centers" which enable routing of telephone calls to suitable contributors or collegues of a called participiant and which 
provide a computer user with utilities allowing activation of telephone functions out of a standard application environ- 

20 ment Another class of exemplary applications are dialing support tools in the arena of "tele banking". 

In a common architecture of existing CTI applications as depicted in Fig. 1 , a first computer 1 is connected to a tel- 
ephone switching system 2 over a physical interface 3, for instance the interface definition standard "V24" or the stand- 
ardized Integrated Services Digital Network (ISDN). Through that connection control commands and messages can be 
exchanged between the first computer and the switching system according to a defined communication protocol. On 

25 the other side, a second computer 4, as a server for the locally or distantly located applications (clients), provides the 
functionality of the switching system to the applications. 

There exist a number of proprietary or standardized CTI interfaces like the TSAPr by Novell. TAPI" by Micro- 
soft/Intel, or the prementioned "CallPath" by IBM. In general, the switching network functions are provided to the appli- 
cation programs as an application program interface (API). Those approaches are broadly discussed in an overview 

30 article by T. Nixon, entitled The Design Considerations for Computer-Telephony Application Programming Interfaces 
and Related Components" and published in IEEE Communications Magazine vol. 34, no. 4 (1996), pages 43-47. 

An according approach where a server is attached directly to a telephone switch - in contrast to a concept where a 
LAN server has to pass telephony signalling to the telephone switch (PBX) over the LAN - is disclosed in an article by 
S. Rudd, entitled "Where do CTI Applications really belong?", published in Business Communications Review, vol. 26, 

35 no. 2 (1 996), pages 23-26. The advantage of that concept is that a CTI application not tightly coupled with LAN-attached 
databases will perform for better and cost much less. 

A comparison between known mainframe PBX systems and an approach where a widely cfistrfouted group of CTI 
servers is linked through an isochronous broadband backbone, is given in an article by L Goldberg, entitled "CTI Com- 
puter/Phone Fusion at LAN's Edge" and published in Electronic Design vol. 42, no. 22 (1 994), pages 77-90. These serv- 

40 ers can be configured to route calls, or they also may take on more specialized functions such as to becoming an 
interface to a public switch telephone network (PSTN) by acting as an automated attendant, voice-mail server, or any 
other network service. 

There exist further generic solutions in the section of voice mail systems which are direcly attached to the Internet. 
Hereby a telephone call can be performed via a so-called Webphone service. An exemplary system is "DirectTalkMaiP 

45 by IBM. An accorcfing voice mail system is disclosed in PCT application WO entitled "Voice Mail System" and 

assigned to the present assignee (Docketno. UK995024). That system provides access to voice mail over the Internet 
WWW. Hereby a user has to call up a page associated with a respective voice mail system, and to enter a mailbox 
number. A WWW server responds by transmitting a message to the voice mail system itself. A further request may be 
directed from the server to the voice mail system, which results in the voice mail system returning the actual audio data 

so for the message to the user, to be played out. 

In an article by R. Sergeant disclosed in IBM Technical Disclosure Bulletin vol. 38, no. 8 (1995), pages 415-418, 
and entitled "Inexpensive Multimedia Facility for Workstation", amongst others, an arrangement is described which 
allows a same graphical user interface (GUI) to be utilized when a standard desk telephone is used as audio input/out- 
put device. The GUI application sends a comment to a CTI server to ring the telephone at the user's desktop and to set 

55 up a connection. 

A desktop telephone approach can also be integration of Lotus Notes by Lotus (IBM), where client specific modules 
handle messages received by a CTI server. These modules communicate via local Inter Process Communication (IPC) 
means with a Lotus Notes client The Notes client then starts the appropriate actions for the Notes application, depend- 



2 



EP 0 836 295 A2 



ing on the messages received, e.g. "Open specific Databases/Database entries" or "Start application specific actions". 

Further in IBM Technical Disclosure Bulletin vol. 37, no. 1 (1994), pages 357-358, a "Global Multimedia Hyper- 
space" concept is disclosed. According to that concept in case of no direct network link existing between two hyper- 
document nodes, a telephone link is established between two corresponding computer systems. Hereby the hyperlinks 
5 need not be simply a local address, instead, it can be a telephone link to a node residing inside another hyperlinked 
document anyplace in the world. The advantage of this approach is integration of the world in a way analogous to the 
global Internet, global TV network or the global telephone network. 

Known CTI solutions are integrated on a server, like Novel I's Telephony Server, and thus have the drawback that 
due to the various (Afferent operating system platforms, in particular in the area of Personal Computers or Workstations, 
10 an interface has to be adapted to each client's platform i.e. particulary to be compatible with multiple different operating 
systems. 

In older to solve that problem, according to the invention, between a HTTP (WWW) server and a switching system, 
a particular application is provided which enables control of a CTI application, i.e. of a switching unit of the switching 
system, through the HTTP server. In particular, it is proposed to integrate the functionality of a switching network into a 
is WWW server. 

Vis-a-vis existing server solutions for control of switching systems like TSAPI" or "CallPath", the proposed applica- 
tion has the advantage to provide an interface which uses a Universal Resource Locator (URL). The URL, according to 
the invention, specifies high level communicating functions like 'set up connection', terminate connection', add particip- 
iarrt to connection' (telephone conference), or 'remove partidpianf. which are independent of the respective interface to 

20 the switching system or the CTI server. 

Further command processing at the CTI interface is accomplished in accordance with a request-response protocol 
known from HTTP. Therefore intermediate slates of command processing which occur due to protocol of interaction 
with the switching system, are handled by the processor and are thus transparent to the user. 

In a typical scenario of running a CTI application in accordance with the invention, a user specifies a desired CTI 

25 function by using a common WWW browser. The browser forwards the functional request as a HTTP request to a 
respective WWW server known to the user. The server converts the request into arguments for a (e.g. CGI) executable 
function calling up the CTI application. The resulting message of executing the CTI application generated by the server 
is then re-transmitted to the WWW server. The server then informs the WWW browser about the result by using a 
respective HTTP response command. 

30 Through use of HTTP being a standard protocol for the client-server communication, the proposed mechanism pro- 
vides an open solution concept. Thereupon, WWW access is becoming very widespread, from many cfifferent plat- 
forms, and the according HTTP communication protocol, too, with respect to Hs use as WWW protocol on the Internet. 
The HTTP further enhances its relevance by its use in the so-called "Intranets" utilized proprietarily by networks of pri- 
vate firms. 

35 The extensive widening of HTTP clients (WWW browsers) in nearly all today existing computer system platforms 
has the advantageous effect that for the control of the switching system, no specialized application programs are 
required on the client's side. Moreover, according to state of the art solutions, these applications had to be developed 
separately for each operating system platform. 

In the following, a preferred embodiment of the invention is described in more detail with reference to the accom- 

40 parrying drawings, where 

Rg. 1 depicts a state-of-the-art architecture of a CTI application where a computer is connected to a telephone 
switching system over a physical interface; 

45 Rg. 2 is a schematic view of the protocol interaction between a common telephone switching system and a HTTP 
client in accordance with the invention; and 

Rg. 3a-d are protocol diagrams shewing four different conversion cases of common telephony commands between 
a HTTP server and a telephone switching system. 

so 

In the preferred embodiment illustrated now with reference to Rg. 2, the invention is implemented as a control pro- 
gram (application) called "WebCT Processor 20 which is interposed between an interface layer 21 provided by a HTTP 
(e.g. WWW) server 22 and a common (telephone) switching system 23. That processor 20 enables control of the 
switching system through the HTTP server 22. ft is hereby emphasized that the invention is not restricted to the field of 
55 HTTP servers, but moreover can be used in all kinds of networks which utilize a generic network communication proto- 
col. Further, besides realization as a computer program, the invention can also be implemented as a hardware control 
unit providing the beforehand cited functionality which is described in more detail in the following. 

For an interaction between an HTTP client 24 and the switching system 23, the HTTP client 24 sends an according 
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request 25 to the HTTP server 22, e.g. the request to set up a connection with a participant identified by a subscriber 
number. In the preferred embodiment, the request 25 involves as uniform resource locator (URL) information coded 
telephony commands which have to be translated by the WebCT processor 20 into respective commands which can be 
interpreted by the switching system 23. Through the transferred URLs, the HTTP server 22 is instructed to start, over 
the server interface 21 , an according telephony process related to the request 25. The server interface 21 to the switch 
can be a Common Gateway Interface (CGI) which is a de facto standard interface, the Netscape Server API (NSAPI) 
by Netscape, or another equivalent proprietary or standard interlace. By that process the precited commands which are 
coded with respect to the respective interface 21 , are delivered to the switching system 23. It is noted that in the pre- 
ferred embodiment the above process is identical with the WebCT processor 20 which then takes over control of the 
communication with the switching system 23. 



WebCrr/HTTP Server Interface 

The telephony commands are transferred as parameters to the WebCT processor 20 which is called up by the 
HTTP server 22 via the server interface 2 1 . The WebCT processor 20 controls the whole interaction with the switching 
system 23. The commands delivered to the WebCT processor 20 are coded as URLs according to the following exem- 
plary URL syntax. 



REQ : := http: //host:port/path?<Param> 

Param ::= <Param> & <Cmd> | <Cmd> 

Cmd : : = <op> - <val> 

op :: = call | add | reduce | disc | caller | <SSCtl> 

val ::= <SSCtl> | <digits> 

digits : := <digits><digit> | <digit> 

digit ::=0|1|2|3|4|5|6|7|8|9 

SSCtl : := <Switching system specific control commands) 



Mapping of URLs onto Switching System Interface 

Trie diagrams depicted in Fig. 3a-d illustrate, for the following basic telelephony functions, conversion of the com- 
mands which are delivered to the WebCt processor through U RLs: 

a) Set up connection; 

b) Terminating connection; 

c) Add partictpiant to conference call; 

d) Remove participiant of conference call; 

wherein the switching system is controlled by use of a switching system control report (SSCtl). 

The WebCT processor takes over the conversion (translation) of the HTTP commands into the communication pro- 
tocol of the respective telephone switching system. Intermecfiate states which occur during the communication phase 
(see Rg. 3a-d, right columns which are concerned with processes running on the switching system side), are handled 
independently by the WebCT peocessor. After having finished an interaction with the switching system, a respective 
response to the user is generated. 

In order to enable communication which is independent of the physical interface to the switching system, the com- 
mands to the switching system are described in accordance with the standard "CSTA" (Services for Computer Sup- 
ported Telecommunications Applications). The commands depicted in each of the right columns of Rg. 3a-d, 
respectively, are taken from the latter standard. 
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Mapping of the Communication Protocol via CGI 

In case of using a Common Gateway Interface (CGI) as HTTP server interface, the submission of parameters is 
accomplished, depending on the respective HTTP request procedure, either via program parameter (GET) or via a 
standard entry (POST). Thereupon the server interface utilizes other parameters for handling further information con- 
cerning the HTTP client, which are not essential for the present invention. 

Use of the CGI interface has the advantage that the implementation of the invention is simplified by existing and in 
the public available modules. The only disadvantage is that for each request a new process according to the pre- 
descrbed WebCT processor has to be initiated. Use of a common application program interface (API) can avoid this 
drawback, but those interfaces are not standardized and therefore a solution according to the invention would depend 
on a specific HTTP server. 

In the following, an exemplary code for handling WebCT requests over the CGI interface of the HTTP server is 
shown. The code is written by Larry Wall in "perl" language, wherein the used "CGI.pm" parsing modile is developed 
by Lincoln D. Stein, ft is noted that use of an other server interface, for instance "NSAPI" by Netscape, is also possible. 

#!/usr/bin/perl -w 
use CGI; 
use strict; 

*#*###*#*# 
* 

#fail() 
4 

sub fail { 

my $qy = @_; 

# Send back html containing failure explanation 

} 



###*##*### 
* 

#ok() 
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sub ok { 

my $qy = @ ; 

# Send back html containing status 

> 

<#***#*### 
# 

#caU() 
I 

sub call { 

my $qy = 

my ($caller, $CMD, $op); 

# Requestor's phone # 

# Also serves as an Id for the current call 
$ caller - $qy->param ( "caller") ; 

# Get potential commands in fcfs fashion 
$CMD = 'CALL' if ($op = $qy->param("cair)) ; 

$CMD = 'ADD* if (!$op && ($op = $qy->param("add"))) ; 
$CMD = 'REDUCE* if (!$op && ($op = $qy->param(*reduce")>); 
$CMD = 'DISC if (!$op && ($op = $qy->param("disc"))) ; 

# More commands go here 

# $op is implied by $CMD 

if ($CMD && ($CMD eq 'DISC* | | $caller)) { 
system ("/usr/cti/webct $CMD $op $caller"); 

} else { 

fail($qy); 
return; 

} 

ok($qy); 

) 

o######## 

# 

# main ( ) 
« 

my $qy - new CGI; 
call($qy); 



In the above exemplary code "#fail(T designates a routine for handling errors (parameters and return codes). Fur- 
ther "okO" is a routine for signalling that everything in the call went well. By the routine "callO" first parameters and local 
variables are defined. The requestor's phone number is stored in the variable 'caller' which also serves as an identrfica- 
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tion (ID) for the current call. It is noted that the syntax "$..." designates definition of a variable 

To get WebCT commands in a "first checked first served fashion" means that commands have a kind of priority like 
CALL>ADD>REDUCE>DISC. For example, an URL like http7/...?add=1234&call=1234&caller=4321 would actually 
make a call since 'call* is checked for first although 'add* comes first. This particular order is rather arbitrary and this 
5 code can be advantageously used as a kind of sanity check. It should be noted that the command 'DISC' ^DISCON- 
NECT) does not need a caller anyway. Depending on an IT condition, a call is started or not (i. a a respective error mes- 
sage is sent back to the requestor), wherein the inner IF block concerns a check whether the process succeeded or not. 
If not, a CGI parameter error (failure) is sent back to the requestor. 

By the "mainO routine new CGI objects are created, i.e. "mainO" handles all CGI related parameters. 

10 

Claims 

1 . Telecommunication system comrising 

is a switching network (5) for enabling telephone connections between telephone clients (6) by use of a switching 

network protocol; 

switching means (2, 23) for controlling said telephone connections by use of switching protocol commands of 
said witching network protocol; 

20 

a computer network (3) for transmitting information between computer clients (1, 24) by use of a computer 
communication protocol; 

said communication system being characterized by 

25 server means (4, 22) for providing computer communication protocol commands for controlling said 

switching means (2, 23); 

protocol integration means (20) provided between said switching means (2, 23) and said server means (4, 
22) for converting said computer communication protocol commands into said switching protocol com- 
30 mands, and vice versa. 

2. System according to claim 1 , where said computer network is a wide area network (WAN) or a local area network 
(LAN) utilizing a HTTP protocol for communication. 

35 3. System according to claim 1 or 2, where said protocol integration means specifies Universal Resource Locator 
(URL) syntax and semantics. 

4. Method for connecting a telephone switching network with a computer network, wherein said switching network 
comprises a switching unit providing a switching network protocol and said computer network comprises at least 

40 one computer server utilizing a computer communication protocol, said method being characterized in that 

providing in said computer server telephony commands for controlling said switching unit; 
mapping said computer commmunication protocol onto said switching network protocol; and 

45 

executing said telephony commands of the computer communication protocol by use of respective control 
commands of said switching network protocol. 

5. Method according to claim 4, wherein said server performs the steps of 

50 

recognizing a Universal Resource Locator (URL) which provides said mapping with a respective syntax and 
semantics; 

starting a process for executing said control commands. 
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FIG. 2 
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Connection Setup 
http-Request 



http-Response 



Status Information in html Format 




FIG. 3A 



Make Call (Calling A, Called B) 



Service Response 



Monitor Start (Connection Id) 



Service Response 



Delivered Event 
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Monitor Stop (Connection Id) 



Service Response 
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http-Request 
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http-Response 
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Service Response 
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Call Cleared (Connection Id) 



Monitor Stop (Connection Id) 



Service Response 



FIG. 3B 
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Add Participant To Conference Call 
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Monitor Stop (Connection Id) 



Service Response 



FIG. 3C 
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http-Request 
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Monitor Stop (Connection Id) 
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